Data Querying এবং Database Transactions গাইড ও নোট

Computer Programming - রুবি প্রোগ্রামিং (Ruby Programming) - Working with Databases (ডেটাবেসের সাথে কাজ)
252

Data Querying এবং Database Transactions হল ডেটাবেস পরিচালনা এবং ডেটার নিরাপত্তা এবং স্বচ্ছতার জন্য অপরিহার্য দুটি প্রক্রিয়া। রুবিতে ActiveRecord (যেটি রুবি অন রেলসের ORM) ব্যবহার করে সহজে ডেটাবেসে কুয়েরি এবং ট্রানজ্যাকশন পরিচালনা করা যায়। এই দুটি প্রক্রিয়া কোডের কার্যকারিতা উন্নত করতে এবং ডেটাবেসের নিরাপত্তা এবং এক্সপ্লোরেশন সহজ করতে সহায়ক।

এখানে আমরা Data Querying এবং Database Transactions এর প্রাথমিক ধারণা এবং রুবি রেলস ব্যবহারে কীভাবে এগুলি ব্যবহার করা হয় তা বিস্তারিতভাবে আলোচনা করব।


১. Data Querying

Data Querying হচ্ছে ডেটাবেস থেকে নির্দিষ্ট তথ্য বা ডেটা বের করার প্রক্রিয়া। রুবি অন রেলসে ActiveRecord কুয়েরি ইন্টারফেস ব্যবহার করে ডেটা রিটার্ন করা সহজ হয়।

ActiveRecord Querying:

  1. find: এটি একটি নির্দিষ্ট আইডি দ্বারা একটি রেকর্ড খুঁজে বের করে।

    user = User.find(1)  # User with ID 1
  2. where: এটি একটি শর্তের ভিত্তিতে এক বা একাধিক রেকর্ড খুঁজে বের করে।

    users = User.where(age: 30)  # All users where age is 30
  3. order: এটি রেকর্ডগুলোকে একটি নির্দিষ্ট ক্রমে সাজাতে ব্যবহৃত হয়।

    users = User.order(:name)  # Order users by name in ascending order
  4. limit: এটি রেকর্ডগুলোর সংখ্যা সীমিত করে।

    users = User.limit(5)  # Fetch only the first 5 users
  5. pluck: এটি শুধুমাত্র নির্দিষ্ট কলামগুলি রিটার্ন করে, পুরো রেকর্ড নয়।

    names = User.pluck(:name)  # Returns an array of names
  6. joins: এটি দুটি টেবিলকে যুক্ত (join) করে ডেটা বের করতে ব্যবহৃত হয়।

    orders = Order.joins(:user).where(users: { age: 30 })
  7. distinct: এটি ডুপ্লিকেট রেকর্ড বাদ দিয়ে ইউনিক রেকর্ডগুলো রিটার্ন করে।

    unique_names = User.select(:name).distinct

উদাহরণ:

# Finding all users with age greater than 25 and ordering by name
users = User.where("age > ?", 25).order(:name)

এখানে, where মেথডটি ২৫ এর বেশি বয়সের সব ব্যবহারকারী খুঁজে বের করে এবং order মেথডটি তাদের নাম অনুসারে সাজিয়ে দেয়।


২. Database Transactions

Database Transactions হল একাধিক ডেটাবেস অপারেশন (যেমন ইনসার্ট, আপডেট, বা ডিলিট) একটি একক ইউনিট হিসেবে সম্পন্ন করার প্রক্রিয়া। যদি কোনো একটি অপারেশন ব্যর্থ হয়, তবে পুরো ট্রানজ্যাকশনটি ব্যর্থ হয়ে পূর্ববর্তী সব পরিবর্তন পূর্বাবস্থায় ফিরে আসে। এই প্রক্রিয়া atomicity (পারফেক্ট একক কার্যক্রম) নিশ্চিত করে।

Transaction Basics:

  • Begin Transaction: ট্রানজ্যাকশন শুরু করা।
  • Commit: সব কিছু ঠিক থাকলে সব পরিবর্তন ডেটাবেসে সংরক্ষণ করা।
  • Rollback: কোনো ত্রুটি ঘটলে, সব পরিবর্তন বাতিল করে পূর্বাবস্থায় ফিরে যাওয়া।

Syntax:

ActiveRecord::Base.transaction do
  # Database operations
end

উদাহরণ:

begin
  ActiveRecord::Base.transaction do
    # Create a new user
    user = User.create!(name: "Alice", age: 25)

    # Create an associated order for the user
    order = Order.create!(user_id: user.id, amount: 100)

    # If any of the above operations fail, the transaction will roll back
  end
rescue ActiveRecord::RecordInvalid => e
  puts "Transaction failed: #{e.message}"
end

এখানে, create! মেথডটি ব্যবহার করা হয়েছে, যা ডেটাবেসে রেকর্ড তৈরি করার সময় ত্রুটি ঘটলে একটি ActiveRecord::RecordInvalid ব্যতিক্রম উত্থাপন করবে। যদি কোনো একটি অপারেশন ব্যর্থ হয়, তবে পুরো ট্রানজ্যাকশনটি rollback হয়ে যাবে এবং কোনো পরিবর্তন ডেটাবেসে সংরক্ষিত হবে না।

২.১ Implicit Transaction (অপ্রকাশিত ট্রানজ্যাকশন)

রুবির ActiveRecord কিছু কাজ স্বয়ংক্রিয়ভাবে একটি ট্রানজ্যাকশনে সম্পন্ন করে, যেমন save, create, update, ইত্যাদি।

উদাহরণ:

user = User.create(name: "Bob", age: 28)
# Even if this fails, no need for explicit transaction

এখানে, যদি কোনো ত্রুটি না ঘটে, তবে রুবি স্বয়ংক্রিয়ভাবে commit করবে এবং যদি ত্রুটি ঘটে, তাহলে rollback হবে।


৩. Nested Transactions (নেস্টেড ট্রানজ্যাকশন)

রুবি আপনাকে nested transactions পরিচালনা করতে দেয়, যেখানে একাধিক ট্রানজ্যাকশন একে অপরের মধ্যে থাকে। তবে, একটি nested transaction যদি commit হয়, তাহলে পুরো ট্রানজ্যাকশনটি সফল হবে।

ActiveRecord::Base.transaction do
  # Outer transaction
  user = User.create!(name: "Charlie", age: 22)

  ActiveRecord::Base.transaction do
    # Nested transaction
    order = Order.create!(user_id: user.id, amount: 50)
  end
end

এখানে, outer transaction এবং nested transaction উভয়ই একটি একক ট্রানজ্যাকশন হিসাবে কাজ করবে, এবং যদি কোনো একটি অংশে সমস্যা হয়, তাহলে পুরো ট্রানজ্যাকশন rollback হয়ে যাবে।


৪. Savepoints (সেভপয়েন্টস)

Savepoint হচ্ছে একটি ট্রানজ্যাকশনের মধ্যে একটি চেকপয়েন্ট, যেখানে আপনি কিছু কাজ সম্পন্ন করার পর সেভপয়েন্টে ফিরে যেতে পারেন।

উদাহরণ:

ActiveRecord::Base.transaction do
  # Initial operation
  user = User.create!(name: "David", age: 30)

  # Set a savepoint
  ActiveRecord::Base.connection.execute('SAVEPOINT user_created')

  begin
    # Another operation that might fail
    order = Order.create!(user_id: user.id, amount: 100)
  rescue => e
    # If error occurs, rollback to the savepoint
    ActiveRecord::Base.connection.execute('ROLLBACK TO SAVEPOINT user_created')
    puts "Order creation failed: #{e.message}"
  end
end

এখানে, একটি savepoint তৈরি করা হয়েছে, এবং যদি order creation ব্যর্থ হয়, তাহলে সেই সেভপয়েন্টে ফিরে গিয়ে user তৈরি হয়ে যাবে, কিন্তু order তৈরি হবে না।


সারসংক্ষেপ

  • Data Querying: রুবিতে ActiveRecord এর মাধ্যমে ডেটাবেস কুয়েরি করা সহজ হয়, যেমন find, where, order, pluck, joins ইত্যাদি মেথড ব্যবহার করে।
  • Database Transactions: ActiveRecord::Base.transaction এর মাধ্যমে আপনি একাধিক ডেটাবেস অপারেশনকে একটানা (atomic) ট্রানজ্যাকশনে পরিচালনা করতে পারেন, যা নিশ্চিত করে যে সব অপারেশন সফল না হলে কোনো পরিবর্তন সংরক্ষিত হবে না।
  • Rollback & Commit: ট্রানজ্যাকশন সফল হলে commit হয় এবং কোনো ত্রুটি ঘটলে rollback হয়।
  • Nested Transactions & Savepoints: নেস্টেড ট্রানজ্যাকশন এবং সেভপয়েন্টস এর মাধ্যমে আপনি ট্রানজ্যাকশনের মধ্যে আরও জটিল কাঠামো তৈরি করতে পারেন।

এই ধারণাগুলোর মাধ্যমে আপনি রুবি অন রেলসে ডেটাবেসের সাথে কার্যকরভাবে কাজ করতে পারবেন এবং ডেটাবেসের কার্যকারিতা ও নিরাপত্তা নিশ্চিত করতে পারবেন।

Content added By
Promotion

Are you sure to start over?

Loading...